<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="80px">
      <el-form-item label="创建人" prop="uname">
        <el-input
          v-model="queryParams.uname"
          placeholder="请输入创建人"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="创建日期" prop="createTime">
        <el-date-picker clearable
          v-model="queryParams.createTime"
          type="date"
          value-format="YYYY-MM-DD"
          placeholder="请选择创建日期">
        </el-date-picker>
      </el-form-item>
      <el-form-item label="党员名称" prop="householdName">
        <el-input
          v-model="queryParams.householdName"
          placeholder="请输入户主名称"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="家庭地址" prop="familyAddress">
        <el-input
          v-model="queryParams.familyAddress"
          placeholder="请输入家庭地址"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="证件类型" prop="idType">
        <el-select v-model="queryParams.idType" placeholder="请选择证件类型" clearable>
          <el-option
            v-for="dict in id_type"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="是否烈军烈属" prop="militaryMartyr"
      label-width="100">
        <el-select v-model="queryParams.militaryMartyr" placeholder="请选择是否烈军烈属" clearable>
          <el-option
            v-for="dict in sys_yes_no"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="性别" prop="sex">
        <el-select v-model="queryParams.sex" placeholder="请选择性别" clearable>
          <el-option
            v-for="dict in sys_user_sex"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="证件号" prop="idNumber">
        <el-input
          v-model="queryParams.idNumber"
          placeholder="请输入证件号"
          clearable
          @keyup.enter="handleQuery"
        />
      </el-form-item>
      <el-form-item label="与户主关系" prop="relationHead"
      label-width="100">
        <el-select v-model="queryParams.relationHead" placeholder="请选择与户主关系" clearable>
          <el-option
            v-for="dict in relation_head"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="政治面貌" prop="politicalAffiliation">
        <el-select v-model="queryParams.politicalAffiliation" placeholder="请选择政治面貌" clearable>
          <el-option
            v-for="dict in political_affiliation"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
          />
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
        <el-button icon="Refresh" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="primary"
          plain
          icon="Plus"
          @click="handleAdd"
          v-hasPermi="['town:member:add']"
        >新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="success"
          plain
          icon="Edit"
          :disabled="single"
          @click="handleUpdate"
          v-hasPermi="['town:member:edit']"
        >修改</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="danger"
          plain
          icon="Delete"
          :disabled="multiple"
          @click="handleDelete"
          v-hasPermi="['town:member:remove']"
        >删除</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          plain
          icon="Download"
          @click="handleExport"
          v-hasPermi="['town:member:export']"
        >导出</el-button>
      </el-col>
      <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="memberList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="ID" align="center" prop="id" />
      <el-table-column label="创建人" align="center" prop="uname" />
      <el-table-column label="创建日期" align="center" prop="createTime" width="180">
        <template #default="scope">
          <span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="户主名称" align="center" prop="householdName" />
      <el-table-column label="家庭地址" align="center" prop="familyAddress" />
      <el-table-column label="证件类型" align="center" prop="idType">
        <template #default="scope">
          <dict-tag :options="id_type" :value="scope.row.idType"/>
        </template>
      </el-table-column>
      <el-table-column label="是否烈军烈属" align="center" prop="militaryMartyr">
        <template #default="scope">
          <dict-tag :options="sys_yes_no" :value="scope.row.militaryMartyr"/>
        </template>
      </el-table-column>
      <el-table-column label="性别" align="center" prop="sex">
        <template #default="scope">
          <dict-tag :options="sys_user_sex" :value="scope.row.sex"/>
        </template>
      </el-table-column>
      <el-table-column label="证件号" align="center" prop="idNumber" />
      <el-table-column label="与户主关系" align="center" prop="relationHead">
        <template #default="scope">
          <dict-tag :options="relation_head" :value="scope.row.relationHead"/>
        </template>
      </el-table-column>
      <el-table-column label="政治面貌" align="center" prop="politicalAffiliation">
        <template #default="scope">
          <dict-tag :options="political_affiliation" :value="scope.row.politicalAffiliation"/>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
        <template #default="scope">
          <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['town:member:edit']">修改</el-button>
          <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['town:member:remove']">删除</el-button>
        </template>
      </el-table-column>
    </el-table>
    
    <pagination
      v-show="total>0"
      :total="total"
      v-model:page="queryParams.pageNum"
      v-model:limit="queryParams.pageSize"
      @pagination="getList"
    />

    <!-- 添加或修改党员信息对话框 -->
    <el-dialog :title="title" v-model="open" width="1000px" append-to-body>
      <el-form ref="memberRef" :model="form" :rules="rules" label-width="80px">
        <div class="custom-form">
          <el-divider class="custom-divider"></el-divider>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="户主名称" prop="householdName"
                 label-width="100">
                
                  <el-input v-model="form.householdName" placeholder="请输入户主名称" />
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="家庭地址" prop="familyAddress"
                 label-width="100">
                  <el-input v-model="form.familyAddress" placeholder="请输入家庭地址" />
                </el-form-item>
              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="证件类型" prop="idType"
                 label-width="100">
                  <el-select v-model="form.idType" placeholder="请选择证件类型">
                    <el-option
                      v-for="dict in id_type"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="是否烈军烈属" prop="militaryMartyr" 
                class="label-width"
                label-width="120">
                  <el-radio-group v-model="form.militaryMartyr">
                    <el-radio
                      v-for="dict in sys_yes_no"
                      :key="dict.value"
                      :label="dict.value"
                    >{{dict.label}}</el-radio>
                  </el-radio-group>
                </el-form-item>
              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="家庭成员" prop="familyMembers"
                 label-width="100"
                class="label-width"
                 >
                  <el-input v-model="form.familyMembers" placeholder="请输入家庭成员" />
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="性别" prop="sex"
                 label-width="100"
                class="label-width"
                 >
                  <el-select v-model="form.sex" placeholder="请选择性别">
                    <el-option
                      v-for="dict in sys_user_sex"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="证件号" prop="idNumber"
                 label-width="100"
                class="label-width"
                 >
                  <el-input v-model="form.idNumber" placeholder="请输入证件号" />
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="与户主关系" prop="relationHead"
                 label-width="100">
                  <el-select v-model="form.relationHead" placeholder="请选择与户主关系">
                    <el-option
                      v-for="dict in relation_head"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="政治面貌" prop="politicalAffiliation"
                 label-width="100"
                class="label-width"
                 >
                  <el-select v-model="form.politicalAffiliation" placeholder="请选择政治面貌">
                    <el-option
                      v-for="dict in political_affiliation"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="文化程度" prop="educationLevel"
                 label-width="100"
                class="label-width"
                 >
                  <el-select v-model="form.educationLevel" placeholder="请选择文化程度">
                    <el-option
                      v-for="dict in leader_education"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="健康状态" prop="healthStatus"
                 label-width="100"
                class="label-width"
                 >
                  <el-select v-model="form.healthStatus" placeholder="请选择健康状态">
                    <el-option
                      v-for="dict in health_status"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="劳动能力" prop="laborAbility"
                class="label-width"

                 label-width="100">
                  <el-radio-group v-model="form.laborAbility">
                    <el-radio
                      v-for="dict in sys_yes_no"
                      :key="dict.value"
                      :label="dict.value"
                    >{{dict.label}}</el-radio>
                  </el-radio-group>
                </el-form-item>
              </el-col>
            </el-row>  
            <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="党支部" prop="branch"
                 label-width="100"
                class="label-width"
                 >
                  <el-input v-model="form.branch" placeholder="请输入党支部" />
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="手机号" prop="phone"
                 label-width="100"
                class="label-width"
                 >
                  <el-input v-model="form.phone" placeholder="请输入手机号" />
                </el-form-item>

              </el-col>
          </el-row>
          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="党内职务" prop="post"
                 label-width="100"
                class="label-width"
                 >
                  <el-input v-model="form.post" placeholder="请输入党内职务" />
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="入党时间" prop="branchTime"
                 label-width="100"
                class="label-width"
                 >
                  <el-date-picker clearable
                  v-model="form.branchTime"
                  type="date"
                  value-format="YYYY-MM-DD"
                  placeholder="请选择创建日期">
                </el-date-picker>
                </el-form-item>
              </el-col>
          </el-row>

          <el-row :gutter="20">
              <el-col :span="12" style="text-align: left">
                <el-form-item label="是否受过处分" prop="isPunishment"
                 label-width="110"
                class="label-width"
                 >
                  <el-radio-group v-model="form.isPunishment">
                    <el-radio
                      v-for="dict in sys_yes_no"
                      :key="dict.value"
                      :label="dict.value"
                    >{{dict.label}}</el-radio>
                  </el-radio-group>
                </el-form-item>
              </el-col>
              <el-col :span="12" style="text-align: left"> 
                <el-form-item label="乡镇" prop="town"
                label-width="100"
                class="label-width"
                >
                  <el-select v-model="form.town" placeholder="请选择乡镇">
                    <el-option
                      v-for="dict in town"
                      :key="dict.value"
                      :label="dict.label"
                      :value="dict.value"
                    ></el-option>
                  </el-select>
                </el-form-item>
              </el-col>
          </el-row>
        </div>  
        
        
      </el-form>
      
      <template #footer>
        <div class="dialog-footer">
          <el-button type="primary" @click="submitForm">确 定</el-button>
          <el-button @click="cancel">取 消</el-button>
        </div>
      </template>
    </el-dialog>
  </div>
</template>

<script setup name="Member">
import { listMember, getMember, delMember, addMember, updateMember } from "@/api/town/member";

const { proxy } = getCurrentInstance();
const { relation_head, sys_yes_no, political_affiliation, sys_user_sex, health_status, leader_education, town, id_type } = proxy.useDict('relation_head', 'sys_yes_no', 'political_affiliation', 'sys_user_sex', 'health_status', 'leader_education', 'town', 'id_type');

const memberList = ref([]);
const open = ref(false);
const loading = ref(true);
const showSearch = ref(true);
const ids = ref([]);
const single = ref(true);
const multiple = ref(true);
const total = ref(0);
const title = ref("");

const data = reactive({
  form: {},
  queryParams: {
    pageNum: 1,
    pageSize: 10,
    uname: null,
    createTime: null,
    householdName: null,
    familyAddress: null,
    idType: null,
    militaryMartyr: null,
    sex: null,
    idNumber: null,
    relationHead: null,
    politicalAffiliation: null,
  },
  rules: {
    householdName: [
      { required: true, message: "户主名称不能为空", trigger: "blur" }
    ],
    familyAddress: [
      { required: true, message: "家庭地址不能为空", trigger: "blur" }
    ],
    idType: [
      { required: true, message: "证件类型不能为空", trigger: "blur" }
    ],
    relationHead: [
      { required: true, message: "与户主关系不能为空", trigger: "blur" }
    ],
  }
});

const { queryParams, form, rules } = toRefs(data);

/** 查询党员信息列表 */
function getList() {
  loading.value = true;
  listMember(queryParams.value).then(response => {
    memberList.value = response.rows;
    total.value = response.total;
    loading.value = false;
  });
}

// 取消按钮
function cancel() {
  open.value = false;
  reset();
}

// 表单重置
function reset() {
  form.value = {
    id: null,
    uid: null,
    uname: null,
    createTime: null,
    updateTime: null,
    householdName: null,
    familyAddress: null,
    idType: null,
    militaryMartyr: null,
    familyMembers: null,
    sex: null,
    idNumber: null,
    relationHead: null,
    politicalAffiliation: null,
    educationLevel: null,
    healthStatus: null,
    laborAbility: null,
    town: null
    // branch：null
    // phone:null
  };
  proxy.resetForm("memberRef");
}

/** 搜索按钮操作 */
function handleQuery() {
  queryParams.value.pageNum = 1;
  getList();
}

/** 重置按钮操作 */
function resetQuery() {
  proxy.resetForm("queryRef");
  handleQuery();
}

// 多选框选中数据
function handleSelectionChange(selection) {
  ids.value = selection.map(item => item.id);
  single.value = selection.length != 1;
  multiple.value = !selection.length;
}

/** 新增按钮操作 */
function handleAdd() {
  reset();
  open.value = true;
  title.value = "添加党员信息";
}

/** 修改按钮操作 */
function handleUpdate(row) {
  reset();
  const _id = row.id || ids.value
  getMember(_id).then(response => {
    form.value = response.data;
    open.value = true;
    title.value = "修改党员信息";
  });
}

/** 提交按钮 */
function submitForm() {
  proxy.$refs["memberRef"].validate(valid => {
    if (valid) {
      if (form.value.id != null) {
        updateMember(form.value).then(response => {
          proxy.$modal.msgSuccess("修改成功");
          open.value = false;
          getList();
        });
      } else {
        addMember(form.value).then(response => {
          proxy.$modal.msgSuccess("新增成功");
          open.value = false;
          getList();
        });
      }
    }
  });
}

/** 删除按钮操作 */
function handleDelete(row) {
  const _ids = row.id || ids.value;
  proxy.$modal.confirm('是否确认删除党员信息编号为"' + _ids + '"的数据项？').then(function() {
    return delMember(_ids);
  }).then(() => {
    getList();
    proxy.$modal.msgSuccess("删除成功");
  }).catch(() => {});
}

/** 导出按钮操作 */
function handleExport() {
  proxy.download('town/member/export', {
    ...queryParams.value
  }, `member_${new Date().getTime()}.xlsx`)
}

getList();
</script>
<style lang="scss" scoped>
:deep(.el-form-item__label) {
  display: block;
}

:deep(.el-select.el-select--default) {
  width: 100%;
}

:deep(.el-form-item.el-form-item--default.asterisk-left.label-width label) {
  padding-left: 10px;
}
:deep(
    .el-input.el-input--default.el-input--prefix.el-input--suffix.el-date-editor.el-date-editor--date.el-tooltip__trigger.el-tooltip__trigger
  ) {
  width: 100%;
}

.custom-form {
  max-width: 100%;
  border: 1px solid #ccc;
  padding: 1rem 4rem 0;
}

.form-row {
  margin-bottom: 20px;
}

.custom-divider {
  border-style: dashed; /* 修改边框样式为虚线 */
  border-width: 2px; /* 设置边框宽度 */
  border-color: #ccc; /* 设置边框颜色 */
}
</style>